home *** CD-ROM | disk | FTP | other *** search
- package symantec.itools.db.awt;
-
- import java.awt.Component;
- import java.awt.Event;
- import java.io.IOException;
- import symantec.itools.db.pro.ProjBinder;
- import symantec.itools.db.pro.ProjLink;
- import symantec.itools.db.pro.RelationView;
- import symjava.sql.SQLException;
-
- public class Checkbox extends java.awt.Checkbox implements ProjLink {
- private ProjBinder m_ProjBinder;
- private String m_trueValue = new String("true");
- private String m_falseValue = new String("false");
- private int m_treatBlankAs;
- private boolean m_DynamicUpdate = false;
- private boolean m_ignoreStateChange = true;
-
- public Checkbox(String var1) {
- super(var1);
- }
-
- public Checkbox() {
- }
-
- public void init(ProjBinder var1) {
- this.m_ProjBinder = var1;
- this.setEditable(this.m_ProjBinder);
- }
-
- public void setTreatBlankAs(String var1) {
- if ((new String(var1)).toUpperCase().equals("DEFAULT")) {
- this.m_treatBlankAs = 0;
- } else if ((new String(var1)).toUpperCase().equals("NULL")) {
- this.m_treatBlankAs = 1;
- } else {
- if ((new String(var1)).toUpperCase().equals("BLANK")) {
- this.m_treatBlankAs = 2;
- }
-
- }
- }
-
- public void setBinding(RelationView var1, String var2) {
- try {
- int var3 = var1.findProjByName(var2);
- var1.bindProj(var3, this);
- } catch (SQLException var4) {
- this.raiseException("SQLException from Checkbox.setBinding: " + ((Throwable)var4).getMessage());
- }
- }
-
- public void notifyDataChange(ProjBinder var1) {
- this.m_ignoreStateChange = true;
-
- try {
- if (this.m_trueValue.equals(var1.getStringValue())) {
- ((java.awt.Checkbox)this).setState(true);
- } else {
- ((java.awt.Checkbox)this).setState(false);
- }
- } catch (SQLException var3) {
- this.raiseException("SQLException from Checkbox.notifyDataChange: " + ((Throwable)var3).getMessage());
- } catch (IOException var4) {
- this.raiseException("IOException from Checkbox.notifyDataChange: " + ((Throwable)var4).getMessage());
- }
- }
-
- public boolean notifySetData(ProjBinder var1) throws SQLException {
- return this.notifyStateChange();
- }
-
- boolean notifyStateChange() {
- if (!this.m_ignoreStateChange) {
- try {
- if (this.m_ProjBinder != null && this.m_ProjBinder.isWritable()) {
- if (((java.awt.Checkbox)this).getState()) {
- this.m_ProjBinder.setValueFromString(this.m_trueValue, 0, this.m_treatBlankAs);
- } else {
- this.m_ProjBinder.setValueFromString(this.m_falseValue, 0, this.m_treatBlankAs);
- }
- }
- } catch (SQLException var2) {
- this.raiseException("SQLException from Checkbox.notifyStateChange: " + ((Throwable)var2).getMessage());
- return false;
- } catch (IOException var3) {
- this.raiseException("IOException from Checkbox.notifyStateChange: " + ((Throwable)var3).getMessage());
- return false;
- }
- }
-
- return true;
- }
-
- public boolean handleEvent(Event var1) {
- try {
- this.m_ignoreStateChange = false;
- this.notifySetData(this.m_ProjBinder);
- } catch (SQLException var3) {
- this.raiseException("SQLException from Checkbox.handleEvent: " + ((Throwable)var3).getMessage());
- }
-
- return super.handleEvent(var1);
- }
-
- public void setTrueValue(String var1) {
- this.m_trueValue = new String(var1);
- this.notifyDataChange(this.m_ProjBinder);
- }
-
- public void setFalseValue(String var1) {
- this.m_falseValue = new String(var1);
- this.notifyDataChange(this.m_ProjBinder);
- }
-
- void setEditable(ProjBinder var1) {
- ((Component)this).disable();
-
- try {
- if (var1 != null) {
- RelationView var2 = var1.getRelationView();
- if (var2 != null && var2.getCurrentRecordState() != 105) {
- ((Component)this).enable();
- return;
- }
- }
- } catch (SQLException var3) {
- this.raiseException("SQLException from Checkbox.setEditable: " + ((Throwable)var3).getMessage());
- }
-
- }
-
- public boolean gotFocus(Event var1, Object var2) {
- return super.gotFocus(var1, var2);
- }
-
- void raiseException(String var1) {
- System.out.println(var1);
- }
-
- public void setDynamicUpdate(boolean var1) {
- this.m_DynamicUpdate = var1;
- }
- }
-